<!DOCTYPE html>
<html lang="en" xmlns:th="http://www.thymeleaf.org">
<head>
    <meta charset="UTF-8">
    <title>员工管理</title>
</head>
<body class="hold-transition skin-black sidebar-mini">
    <div th:replace="common/fragment :: link"></div>
    <div class="wrapper">
        <div th:replace="common/fragment :: navbar"></div>
        <div th:replace="common/fragment :: menu"></div>
        <div class="content-wrapper">
            <section class="content-header">
                <h1>员工编辑</h1>
            </section>
            <section class="content">
                <div class="box">
                    <form class="form-horizontal" action="/employee/saveOrUpdate" method="post" id="editForm" >
                        <input type="hidden" name="id" th:value="${employee?.id}">
                        <div class="form-group" style="margin-top: 10px;">
                            <label class="col-sm-2 control-label">用户名：</label>
                            <div class="col-sm-6">
                                <input type="text" th:disabled="${employee != null}" class="form-control" th:value="${employee?.username}" name="username" placeholder="请输入用户名">
                            </div>
                        </div>
                        <div class="form-group" style="margin-top: 10px;">
                            <label class="col-sm-2 control-label">真实姓名：</label>
                            <div class="col-sm-6">
                                <input type="text" class="form-control" th:value="${employee?.name}" name="name"  placeholder="请输入真实姓名">
                            </div>
                        </div>
                        <div th:if="${employee==null}" class="form-group"> <!--添加用户的时候需要填写密码；修改用户数据的时候不需要-->
                            <label for="password" class="col-sm-2 control-label">密码：</label>
                            <div class="col-sm-6">
                                <input type="password" class="form-control" th:value="${employee?.password}"  id="password" name="password" placeholder="请输入密码">
                            </div>
                        </div>
                        <div th:if="${employee==null}" class="form-group">
                            <label for="repassword" class="col-sm-2 control-label">验证密码：</label>
                            <div class="col-sm-6">
                                <input type="password" class="form-control" id="repassword" name="repassword" placeholder="再输入一遍密码">
                            </div>
                        </div>
                        <div class="form-group">
                            <label for="email" class="col-sm-2 control-label">电子邮箱：</label>
                            <div class="col-sm-6">
                                <input type="text" class="form-control" th:value="${employee?.email}" id="email" name="email" placeholder="请输入邮箱">
                            </div>
                        </div>
                        <div class="form-group">
                            <label for="age" class="col-sm-2 control-label">年龄：</label>
                            <div class="col-sm-6">
                                <input type="text" class="form-control" th:value="${employee?.age}" id="age" name="age" placeholder="请输入年龄">
                            </div>
                        </div>
                        <div class="form-group">
                            <label for="dept" class="col-sm-2 control-label">部门：</label>
                            <div class="col-sm-6">
                                <select class="form-control" id="dept" name="dept.id">
                                    <option>请选择</option>
                                    <option th:each="department,stat:${departments}"
                                            th:text="${department.name}"
                                            th:value="${department.id}"
                                            th:selected="${employee?.dept?.id}"
                                            ></option>
                                </select>
                            </div>
                        </div>
                        <div class="form-group" id="adminDiv">
                            <label for="admin" class="col-sm-2 control-label">超级管理员：</label>
                            <div class="col-sm-6" style="margin-left: 15px;">
                                <input type="checkbox" th:checked="${employee?.admin}" id="admin" name="admin" class="checkbox" >
                            </div>
                        </div>
                        <div class="form-group" id="roleDiv">
                            <label for="role" class="col-sm-2 control-label">分配角色：</label><br/>
                            <div class="row" style="margin-top: 10px">

                                <!--左边的框-->

                                <div class="col-sm-2 col-sm-offset-2">
                                    <select multiple class="form-control allRoles" id="role" style="height: 350px;" size="15">
                                        <option th:each="role,stat:${roles}"
                                                th:value="${role.id}"
                                                th:text="${role.name}"></option>
                                    </select>
                                </div>
                                <div class="col-sm-1" style="margin-top: 60px;" align="center">
                                    <div>

                                        <a type="button" class="btn btn-primary  " style="margin-top: 10px" title="右移动"
                                           onclick="moveSelected('allRoles', 'selfRoles')">
                                            <span class="glyphicon glyphicon-menu-right"></span>
                                        </a>
                                    </div>
                                    <div>
                                        <a type="button" class="btn btn-primary " style="margin-top: 10px" title="左移动"
                                           onclick="moveSelected('selfRoles', 'allRoles')">
                                            <span class="glyphicon glyphicon-menu-left"></span>
                                        </a>
                                    </div>
                                    <div>
                                        <a type="button" class="btn btn-primary " style="margin-top: 10px" title="全右移动"
                                           onclick="moveAll('allRoles', 'selfRoles')">
                                            <span class="glyphicon glyphicon-forward"></span>
                                        </a>
                                    </div>
                                    <div>
                                        <a type="button" class="btn btn-primary " style="margin-top: 10px" title="全左移动"
                                           onclick="moveAll('selfRoles', 'allRoles')">
                                            <span class="glyphicon glyphicon-backward"></span>
                                        </a>
                                    </div>
                                </div>

                                <!--右边的框-->

                                <div class="col-sm-2">
                                    <select multiple class="form-control selfRoles" style="height: 350px;" size="15" name="roleIds">
                                        <option
                                                th:each="role,stat:${roleList}"
                                                th:text="${role.name}"
                                                th:value="${role.id}"></option>
                                    </select>
                                </div>
                            </div>
                        </div>
                        <div class="form-group">
                            <div class="col-sm-offset-1 col-sm-6">
                                <button type="submit" class="btn btn-primary btn-submit">保存</button>
                                <a href="javascript:window.history.back()" class="btn btn-danger">取消</a>
                            </div>
                        </div>
                    </form>
                </div>
            </section>
        </div>
        <div th:replace="common/fragment :: footer"></div>
    </div>
</body>
<script>
    /*角色的左移右移功能*/
    function moveAll(srcClass, targetClass) {
        $('.' + targetClass).append($('.' + srcClass + "> option"));
    }
    function moveSelected(srcClass,targetClass) {
        $('.' + targetClass).append($('.'+srcClass + "> option:selected"))
    }

    /*超管隐藏角色编辑*/
    var $roleDiv;
    $('#admin').click(function () {
        // 看其是否被选中
        var checked = $(this).prop('checked');
        if (checked) {
            // 被选中
            $roleDiv = $('#roleDiv').remove(); // 备用
        }else {
            // 没有被选中
            $("#roleDiv").after($roleDiv);
        }
    });
    // 渲染完
    if($('#admin').prop('checked')){
        $roleDiv = $('#roleDiv').remove();
    }


    /*角色去重*/

    // 角色去重
    // 获取右边下拉框中option value 的值
    var arr = [];
    $(".selfRoles > option").each(function (i,doEle) {
        arr[i] = $(doEle).val();
    });
    console.log(arr);

    // 遍历左边option，若其value 值存在上面数组中，则删除对应option 元素
    $(".allRoles > option").each(function (i, domEle) {
        var $option = $(domEle);
        var val = $option.val();
        if ($.inArray(val, arr) >= 0) {
            $option.remove();
        }
    });

    /*员工保存时全选右边角色下拉框的选项*/
    /*$(".btn-submit").click(function () {
        // 把右边下拉框 的option 全部选中
        $(".selfRoles > option").prop('selected',true);
        // 发送请求
        $("#editForm").submit();
    });*/

    $("#editForm").bootstrapValidator({
        feedbackIcons: { // 图标
            valid: 'glyphicon glyphicon-ok',
            invalid: 'glyphicon glyphicon-remove',
            validating: 'glyphicon glyphicon-refresh'
        },
        fields:{ // 配置要验证的字段
            username:{
                validators:{ // 验证的规则
                    notEmpty:{ // 不能为空
                        message:"用户名必填" // 错误时的提示信息
                    },
                    stringLength: { // 字符串的长度范围
                        min: 1,
                        max: 5
                    }
                }
            },
            name:{
                validators:{ // 验证的规则
                    notEmpty:{ // 不能为空
                        message:"姓名必填" // 错误时的提示信息
                    },
                    stringLength: { // 字符串的长度范围
                        min: 1,
                        max: 5
                    }
                }
            },
            password:{
                validators:{
                    notEmpty:{ // 不能为空
                        message:"密码必填" // 错误时的提示信息
                    },
                }
            },
            repassword:{
                validators:{
                    notEmpty:{ // 不能为空
                        message:"密码必填" // 错误时的提示信息
                    },
                    identical: {// 两个字段的值必须相同
                        field: 'password',
                        message: '两次输入的密码必须相同'
                    },
                }
            },
            email: {
                validators: {
                    emailAddress: {} // 邮箱格式
                }
            },
            age:{
                validators: {
                    between: { // 数字的范围
                        min: 18,
                        max: 60
                    }
                }
            }
        }
    }).on('success.form.bv', function(e) { // 自定义验证通过之后要做什么事情，默认把表单提交了
        // 阻止表单提交
        e.preventDefault();
        $('.selfRoles > option').prop('selected', 'true');
        // TODO 这里可以改成用异步的方式提交表单
        $.post("/employee/saveOrUpdate", $("#editForm").serialize(),function (data) {
            if (data.success) {
                location.href="/employee/list"
            }else{
                Swal.fire(data.msg);
            }
        })

    });




</script>
</html>